// 配置路由
import Vue from "vue";
import VueRouter from "vue-router";
// 引入拆分出去的路由文件
import routes from "./routes"
//引入store
import store from "@/store";

// 使用插件
Vue.use(VueRouter)

// 备份 VueRouter 原型对象的 push、replace, 先保存一份
let originPush = VueRouter.prototype.push;
let originReplace = VueRouter.prototype.replace;
// console.log(originPush)
// console.log(originReplace)

// 重写 push
// 第一个参数：location 告诉原来 push 方法，你往哪里跳转（传递哪些参数）
// 第二个参数：resolve 成功回调
// 第三个参数：reject 失败回调
// call || apply 区别
// 相同点，都可以调用函数一次，都可以篡改函数的上下文一次
// 不痛点：call 与 apply 传递参数：call 传递参数用逗号隔开，apply 方法执行，传递数组
VueRouter.prototype.push = function (location, resolve, reject) {
    if (resolve && reject) {
        originPush.call(this, location, resolve, reject);
    } else {
        originPush.call(this, location, () => {
        }, () => {
        })
    }
}

// 重写 replace 方法
VueRouter.prototype.replace = function (location, resolve, reject) {
    if (resolve && reject) {
        originReplace.call(this, location, resolve, reject);
    } else {
        originReplace.call(this, location, () => {
        }, () => {
        })
    }
}


// 配置路由
let router = new VueRouter({
    routes,
    // 滚动行为
    scrollBehavior(to, from, savedPosition) {
        //返回的这个y=0，代表的滚动条在最上方
        return {y: 0};
    }
})

//全局守卫：前置守卫（在路由跳转之间进行判断）
router.beforeEach(async (to, from, next) => {
    //to:获取到要跳转到的路由信息
    //from：获取到从哪个路由跳转过来来的信息
    //next: next() 放行  next(path) 放行
    //方便测试 统一放行
    //  next();
    //获取仓库中的token-----可以确定用户是登录了
    let token = store.state.user.token;
    let name = store.state.user.userInfo.name;
    //用户登录了
    if (token) {
        //已经登录而且还想去登录------不行
        if (to.path === "/login" || to.path === '/register') {
            next('/'); // 已经登录再访问登录或注册页面，直接跳转到首页
        } else {
            //已经登陆了,访问的是非登录与注册
            //登录了且拥有用户信息，直接放行
            if (name) {
                next();
            } else {
                //登陆了且没有用户信息
                //在路由跳转之前获取用户信息且放行
                try {
                    await store.dispatch('getUserInfo');
                    next();
                } catch (error) {
                    // token失效从新登录
                    await store.dispatch('userLogout');
                    next('/login')
                }
            }
        }
    } else {
        //未登录：不能去交易相关、不能去支付相关【pay|paysuccess】、不能去个人中心
        //未登录去上面这些路由-----登录
        let toPath = to.path;
        if (toPath.indexOf('/trade') !== -1 || toPath.indexOf('/pay') !== -1 || toPath.indexOf('/center') !== -1) {
            //把未登录的时候向去而没有去成的信息，存储于地址栏中【路由】
            next('/login?redirect=' + toPath);
        } else {
            //去的不是上面这些路由（home|search|shopCart）---放行
            next();
        }

    }
});

export default router;

